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(54) CIPHERING APPARATUS 

(57) In a secret-key cryptographic device, there are 
cascade-connected a plurality of round processing . 
parts and the round processing part of each i-th round 
is supplied with input data L { and Rj, nonlinearly trans- 
forms the input data H t in a nonlinear function part on 
the basis of extended key, then provides the exclusive 
OR between the nonlinearly transformed output and the 
input data as data Rj +1 for input into the next round 
and outputs the input data Rj as data for input into 
the next round. The nonlinear function part of each 
round comprises: a key-dependent linear transforma- 
tion part which performs a key<lependent linear trans- 
formation of the input R^ a splitting part which splits the 
linearly transformed output to four pieces of data in 0 , 
in 1( in 2 and in 3 ; first nonlinear transformation parts 
which nonlinearly transform the four split pieces of data 
and output nonlinearly transformed data mid 00 , midoi. 
mid 02 and mido 3 , respectively; a key-dependent linear 
transformation part which associates these transformed 
outputs with each other and. at the same time, linearly 
transforms them based on extended key to output data 
mid 10 , midii, midi 2 and mid 13 ; second nonlinear trans- 
formation parts which nonlinearly transform these trans- 
formed outputs, respectively, and output data outo. out-,, 
out 2 and out 3 ; and a combining part which combines 
these transformed outputs into output data Y. 
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Description 
TECHNICAL FIELD 

5 [0001] The present invention relates to an encryption device for concealing data in data communication or storage 
and, more particularly, to an encryption device of a secret-key algorithm which encrypts or decrypts data in blocks using 
a secret key 

[0002] A typical secret-key algorithm, which is used in an encryption device to conceal data, is the DES (Data 
Encryption Standard) that is a FlPS-approved algorithm for encryption (FIPS 46-3). 

io [0003] Rg. 1 illustrates the functional configuration of the DES. The DES uses a 56-bit secret key to encrypt or 
decrypt data in blocks of 64 bits. In Fig. 1 the encryption process begins with the initial permutation of 64 bits of a plain- 
text P in an initial perminutation part 1 1 which is followed by splitting the transformed data into two pieces of 32-bit block 
data Lo and Rq- The block data Rq is input into a function operation part (which is commonly called a round function) 1 2 
shown as an i-th round processing part 14j (i=0, 1 15) in Fig. 2, wherein it is transformed to f(R 0 , ko) using a 48-bit 

15 extended key k^ This transformed data (R 0 , ko) and the block data Lq are exclusive ORed in an XOR circuit 13, and its 
output and the block data R 0 are interchanged to obtain the next block data , R-) . That is, 

R 1 =L 0 eF(R 0 ,k 0 ) (1) 

20 L., = R 0 

[0004] A 0-th round processing part 14 0 is comprises an operation part 12, an exclusive OR circuit 13 and a data 
swapping part, by which two pieces of input data Lq and R 0 are subjected to round processing to provide output block 
data L| and R 1t and similar round processing parts 14 1 to 14 15 are provided In cascade. The processing by the i-th 
25 round processing part 14j will hereinafter be referred to as i-th processing, where i=0, .... 15. That is, each round 
processing part 14j (0<i< 15) performs the following processing 

R W1 ^effRi.ki) (2) 

30 L w =R j 

and finally combines two pieces of data R 16 and L 1 6 into 64-bit data, which is transformed in a final permutation part 1 5 
to provide a 64-bit ciphertext. The decryption processing can be performed following the same procedure as that for the 
encryption processing except inputting extended keys ko, k 1f k 14 , k 15 into a function f in the order k 15 , k 14 , .... k 1f ko 

35 which is reverse to that in the encryption processing. In such an instance, the outputs L 16 and R 16 from the final round 
processing part 14 15 are further swapped as depicted, and in the decryption processing the plaintext is provided intact 
at the output of the final permutation part 15 by inputting the ciphertext into the initial permutation part 11 to subject it 
to the processing of Fig. 1 . Of course, exactly the same result could be obtained even by providing data to the final per- 
mutation part 15 without swapping the outputs of the final round processing part 14 15 . Incidentally, the extended keys 

40 ko, k v .... k 14 , k 15 are generated by extending a 56-bit secret key to 16 48-bit extended keys with a total of 768 bits in 
an extended key generation part 16 separate of the encryption processing. 

[0005] Tine processing in the function operation part 12 is performed as shown in Fig. 2. To begin with, the 32-bit 
block data R-j is transformed to 48-bit data E(R-() in an extended permutation part 1 7. This output data and the extended 
key ki are exclusive ORed in an XOR circuit 18. whose output is transformed to 48-bit data EfR^ek-,, which is then 

45 split to eight pieces of 6-bit sub-block data. The eight pieces of sub-block data are input into different S-boxes St to S 8 

to derive therefrom a 4-bit output respectively. Incidentally, the S-box Sj (j=1 8) is a nonlinear transformation table 

that transforms the 6-bit input data to the 4-bit output data, and this is a part that assumes a key role essentially in pro- 
viding security for the DES. The eight pieces of output data from the S-boxes S-, to S 8 are concatenated again to 32-bit 
data, which is applied to a transpose part 19to obtain an output ffR^ k-i) of the function f which is exclusive O Red with 
* so L-, as depicted in Fig. 8. 

[0006] Next, a description will be given of cryptanalysis techniques. A wide variety of cryptanalysis techniques have 
been proposed for the DES and other traditional secret-key algorithms; extremely effective cryptanalysis techniques 
among them are a differential cryptanalysis technique proposed by E. Biham and A. Shamir ("Differential Cryptanalysis 
of DES-like Cryptosystems,*' Proceedings of CRYPTO'90) and a linear cryptanalysis technique proposed by Matsui (lin- 

55 ear Cryptanalysis (I) of DES Cryptosystem," The 1993 Symposium on Cryptography and Information Security 1993. 
SCIS93-3C). 

[0007] With the difference between two pieces of data X and X* defined as 
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AX = X©X* (3) 

the differential cryptanalysis aims to obtain the extended key k 15 in the final round by applying to the following equations 
two sets of plaintext-ciphertext pairs that an attacker possesses. Let and R-i represent two pieces of block data for a 
5 first plaintext input into each round processing part 14j of Fig. 1 and L*i and R* represent two pieces of block data for 
a second plaintext input into each round processing part 14j. And let it be assumed that ciphertexts are provided in 
response to the input of these first and second plaintexts. Under the definition of Eq. (3), it holds that 

ALj = L j©L* , (4) 

10 

AR j =Rj©Rv 

In Fig. 1. since L 15 = R 14 , L* 15 = R* 14 , L 16 = R 15 and L* 16 = R* 15 . the following equations hold 
is R 16 = L 15 ©f(R 15 , k 15 ) (5) 

R *16 = L *15 ef ( R *15- k 15) 

and the exclusive OR of both sides of these two equations is obtained as follows: 

20 

AR l6 =AL l5 ef(L 16 ,k 15 )ef(L l6 ©AL 16 ,k l5 ) (6) 

The exclusive ORing of its both sides with AR 14 = AL 15 gives the following equation: 

25 f(L 16 , k 15 )©f((L 16 ©AL 16 ),k 15 ) =AR 16 ©AR 14 (7) 

At this time, L 16 , AL 16 and AR 16 are data available from the ciphertext, and hence they are known information. Hence, 
if the attacker can correctly obtain AR 14 , then only k 15 in the above equation becomes an unknown constant; the 
attacker can find a correct k 15 without fail by making an exhaustive search for k 15 through utilization of the known sets 
30 of plaintext-ciphertext pairs. On the other hand, AR 14 is difficult in general to obtain since this value is an intermediate 
difference value. Then; assume that the (each round processing part 14j are approximated by the following equations 
with a probability P t in each of the 0-th to the last round but one: 

AR j+1 = ALj(&A{f(AR|)} (8) 

35 

AL M =AR M 

The point is that when certain ARj is input, A{f(ARj)} can be predicted with the probability Pj regardless of the value of 
the extended key kj. The reason for which such approximations can be made is that A{f(ARj)} is affected only by the S- 

40 box part which is a nonlinear transformation table, and that according to the input differences thereto, the S-boxes pro- 
vide an extremely uneven distribution of difference outputs. For example, in the S-box S1, an input difference "1 10100" 
is transformed to an output difference "0010" with a probability of 1/4. Then, the approximation for each round is 
obtained by assuming that each S-box is capable of predicting the relationship between the input difference and the out- 
put difference with a probability of p si and by combining them. Furthermore, the concatenation of such approximations 

45 in the respective rounds makes it possible to obtain AR 14 from ALo and ARq (ALq and ARq are data derivable from the 
plaintext, and hence they are known.) with a probability of P=npj. Incidentally, the higher the probability P, the easier the 
cryptanalysis. After the extended key k 15 is thus obtained, a similar calculation is made of the extended key k 14 regard- 
ing it as a 1 5-round DES that is one round fewer than in the above; such operations are repeated to obtain the extended 
keys one by one to ko- 

50 [0008] Biham et at. say that the DES could be broken by this cryptanalysis if 2 47 sets of chosen plaintext-ciphertext 
pairs are available. 

[0009] The linear cryptanalysis aims to obtain extended keys by constructing the. following linear approximate 
expression and using the maximum likelihood method with sets of known plaintext-ciphertext pairs to the attacker. 

55 (L 0 . R 0 ) -r (L 0 . R 0 )©(L 16 . R 16 ) • r(L 16 , R 1G ) = (k 0 , k 1 k 15 ) -r(k 0 . k, k 15 ) (9) 

where rpQ represents the vector that chooses a particular bit position of X, and it is called a mask value. 

[0010] The role of the linear approximate expression is to approximately replace the cryptographic algorithm with a 
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linear expression and separate it into a part concerning the set of plaintext and ciphertext and a part concerning the 
extended key. That is, in the set of plaintext-ciphertext pair, the exclusive ORs between the values at particular bit posi- 
tions of the plaintext and those of the ciphertext all take a fixed value, which indicates that it equals the exclusive OR of 
the values at particular bit positions of extended keys. This means that the attacker gets information 

5 

(k 0 ,k 11 ... ( k 15 )-r(k 0 .k 1 k 15 )(i bit) 

from information 

10 (L 0 , R 0 ) -r(L 0 , R 0 )©(L 16 , R 16 ) -r(L 16 , R 16 ). 

At this time, (Lq, Ro) and (L 16( R 16 ) are the plaintext and the ciphertext, and hence they are known. For this reason, if 

the attacker can correctly obtain r(Lo, R 0 ), r(L 16 , R 16 ) and r(ko, k-,, .... k 15 ) , then he can obtain (ko, ^ k 15 ) -r(ko, 

k 1 ,...,k 15 )(1bit). 

;5 [001 1 ] In the DES, it is only in the S-box that the nonlinear transformation is performed; hence, if only the S-box can 
be linearly represented, the linear approximate expression can easily be constructed. Then, assume that each S-box 
Sj can be linearly represented with a probability of p si . The point here is that when the input mask value for the S-box is 
given, its output mask value can be predicted with the probability of p si . The reason for this is that the S-boxes, which 
form a nonlinear transformation table, provide an extremely uneven distribution of difference mask values according to 

20 the input mask values. For example, in the S-box S5, when the input mask value is "010000," an output mask value 
"11 11 " is predicted with a probability of 3/16. By combining mask values in these S-boxes, a linear approximation can 
be made in each round between the input mask value and the output mask value with a probability Pj, and by concate- 
nating the linear approximations in the respective rounds, r(Lo, R 0 ). r(L 16 , R 16 ) and r(ko, k 1( .... K15) are obtained with 
the following probability: 

25 

P-2 rv1 n|p 1 -1/2| (10) 
Here, the higher the probability P, the easier the cryptanalysis. 

[0012] According to Matsui, he has succeeded in the analysis of the DES by this cryptanalysis through utilization 

30 of 2^ sets of known plaintext-ciphertext pairs. 

[001 3] To compete against the above cryptanalysis techniques, the probability P needs only to be reduced to a suf- 
ficiently low. Accordingly, a wide variety of proposals have been made to lessen the probability P, and the easiest way 
to provide increased security in. the conventional cryptosystem is to increase the number of rounds. For example, a Tri- 
ple-DES formed by a concatenation of three DESs essentially increases the number of rounds from 1 6 to 48, and it prp- 

35 vides a far lower probability P than in the case of the DES. 

[0014] However, to increase the number of rounds with a view to competing against the cryptanalysis techniques 
described above inevitably enlarges the scale of the cryptographic device used and increases the amount of data to 
process as well. For example, if the number of rounds is tripled, the workload for encryption will also increase threefold. 
That is, since the encryption speed of the present DES is about 10 Mbps in the Pentium PC class, the encryption speed 

40 of the Triple-DES goes down to around 3.5 Mbps. On the other hand, networks and computers are becoming increas- 
ingly faster year by year, and hence there is also a demand tor encryption devices that keep up with such speedups. 
With conventional cryptographic devices, it is extremely difficult, therefore, to simultaneously meet the requirements of 
speedup and security. 

[0015] The present invention is intended to obviate the abovesaid defects of the prior art and has for its object to 
45 provide a cryptographic device that satisfies the security requirement without increasing the number of rounds. 

DISCLOSURE OF THE INVENTION 

[001 6] The present invention is characterized in that a nonlinear function part, in particular, is provided with: a key- 
so dependent linear transformation part which linearly transforms input data of the nonlinear function part based on key 
data stored in a key storage part; a splitting part which splits the output data of the key-dependent linear transformation 
part to a plurality of bits strings; first nonlinear transformation parts which nonlinearly transform these split bit strings, 
respectively; a first linear transformation part which linearly transforms the respective output bits strings of the first non- 
linear transformation parts in association with each other; second nonlinear transformation parts which nonlinearly 
55 transform some or ail of the output bit strings of the first linear transformation part: and a combining part which com- 
bines the output bit strings of the second nonlinear transformation parts into output data of the nonlinear function part. 
[001 7] To provide increased security, the invention is characterized by a second linear transformation part which lin- 
early transforms the output data of the combining part to the output data of the nonlinear function part 
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[0018] Furthermore, the invention is characterized in that either one or both of the first and second linear transfor- 
mation parts are key-dependent linear transformation parts which linearly transform the input data thereto based on key 
data stored in the key storage part. 

[0019] According to the present invention, it is guaranteed that when the probability in the S-boxes is p si ^ p b <1 
5 (where P b is the maximum differential or linear probability in the S-boxes), the probability of approximating each round 
is Pi < P b 2 (when the input difference to the function f is not 0 in the case of the differential cryptanalysis, and when the 
output mask value from the function f is not 0 in the case of the linear cryptanalysis). And when the function f is bijective 
(in which case a different input always provides a different output), if the number of rounds of the cipher is set at 3m, 
then the probability of the cipher becomes P <, Pj 2m <> Pb 4m . In general, cipher are regarded as being secure against the 
io differential and linear cryptanalysis schemes if P < 2" 64 ; hence, rt is necessary only to satisfy m >-16/{log 2 (p b )} , and 
if p^ ^ 2* 4 , it is possible to ensure security with a smaller number of rounds than 16 rounds needed in the DES. The 
probability of security changes for each multiple of m rounds. 

[0020] The present invention ensures security against the differential and linear cryptanalysis with a relatively small 
number of rounds, and hence it permits implementation of a cryptographic device which copes with both security and 
75 low workload. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0021] 

20 

Fig. 1 is diagram depicting the functional configuration of a conventional DES cryptographic device. 
Fig. 2 is a diagram depicting a concrete functional configuration of an f-functional calculus part 12 in Fig. 1 . 
Fig. 3 is a diagram illustrating the functional configuration of Embodiment 1 of the present invention. 
Fig. 4 is a diagram showing in detail an example of the functional configuration of a nonlinear function part 304 in 
25 Embodiment 1 . 

Fig. 5 is a diagram depicting a concrete example of a key-dependent linear transformation part 347 in Fig. 4. 
Fig. 6 is a diagram illustrating the functional configuration of Embodiment 2 of the present invention. 
Fig. 7A is a diagram showing in detail the functional configuration of a nonlinear function part 304 in Embodiment 2. 
Fig. 7B is a diagram showing a concrete example of a linear transformation part 354 in the nonlinear function part 
30 304. 

Fig. 8 is a diagram illustrating the functional configuration of Embodiment 3 of the present invention. 

Fig. 9 is a diagram showing in detail the functional configuration of a nonlinear function part 304 in Embodiment 3. 

BEST MODE FOR CARRYING OUT THE INVENTION 

35 

EMBODIMENT 1 

[0022] An embodiment of the present invention will be described below with reference to the accompanying draw- 
ings. 

40 [0023] Pig. 3 depicts the functional configuration for an encryption procedure in the cryptographic device according 
to an embodiment of the present invention. The cryptographic device of the present invention also splits input data to 
two pieces of block data Lq and R 0 and subjects them to round processing by n cascade-connected round processing 
parts 38q to 38 fv1 in a sequential order; each round processing part 38j (i=0, 1 n-1) is made up of a nonlinear func- 
tion part 304 corresponding to the round function part 1 2 in Fig. 1 , a linear operation part 305 corresponding to the XOR 

45 circuit 13 in Fig. 1 and a swapping part 306. 

[0024] Input data P, which corresponds to a plaintext, is entered into the cryptographic device via an input part 301 . 
The following key data is generated in advance by a extended key generation part 321 on the basis of the data input 
thereto from a key input part 320 and stored in a key storage part 322. 

50 " {* k * k 00- k 10' k 20 ; k 01 ■ k 11» k 21 i— i k 0(n-1) ' k 1(n-1) * k 0(n-1) • ek } 

The input plaintext data P is transformed in a key-dependent initial linear transformation part 302 with the extend key fk 
stored in the key storage part 322, thereafter being split in an initial splitting part 303 to two pieces of block data Lq and 
Rq. For example, 64-bit data is split to two pieces of 32-bit block data Lq and Ro- The block data Rq is input to the non- 
55 linear function part 304 of the 0-th round processing part 38 0 . together with the extended key koo. k 10 and k 2 o stored in 
the key storage part 322, and in the nonlinear function part it is transformed to data Y 0 . The data Y 0 and the block data 
Lq are transformed to data Lo* through an operation in the linear operation part 305. The data Lq* and the block data 
Ro are subjected to data-position swapping in the swapping part 306 to provide L 1 = R 0 and R =L 0 *; L 1 and R-i are 
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fed to the next first round processing part 38-j . 

[0025] Thereafter, in an i-th round processing part 38j (i=1, .... n-1) the same processing as described above is 
repeated for two pieces of block data Lj and Rj. That is, in the i-th round processing part 38j the data Rj, one of the two 
pieces of block data Lj and R s , is input into the nonlinear function part 304, together with the extended key koj, k^ and 
s k 2 j stored in the key storage part 322, and in the nonlinear function part 304 it is transformed to data Y h The data Yj and 
the block data Lj are transformed to data Lj* by an operation in the linear operation part 305. The data Lj* and the data 
Rj are swapped in data position in the swapping part 306 to L j+1 = R j and Rj+i = Lj*. The linear operation part 305 is 
one that performs, for instance, an exclusive-OR operation. 

[0026] Letting n represent the repeat count suitable to ensure security of the cryptosystem, two pieces of data Lp 
10 and R n are obtained as the result of such repeated processing by the round processing parts 38 0 to 38^ . These pieces 
of data L„ and R n are combined into a single piece of block data in a final combining part 307; for example, two pieces 
of 32-bit data and R n are combined to 64-bit data. Then the thus combined data is transformed in a key-dependent 
final linear transformation part 308 using the extended key ek stored in the key storage part 322, and output data C is 
provided as a ciphertext from an output part 309. 
15 [0027] To decrypt, the encryption procedure needs only to be reversed, by which the plaintext P can be derived 
from the ciphertext C. This can be done, for example, by inputting ciphertext data in place of the input data in Fig. 3 and 
then inputting the extended key in a sequential order reverse to that in Fig. 3, that is, ek, ko(n-i), k-,^.^, k^t), .... k^, 
kn . k 21 , koo. k t 0.^21. *k- 

[0028] Fig. 4 illustrates the functional configuration of the nonlinear function part 304 used in each round process- 

20 ing part 38j. The block data Rj to the i-th round processing part 38; constitutes input data to the nonlinear function part 
304, together with the extended key k^, j and k 2j stored in the key storage part 322. The block data Rj is linearly trans- 
formed to data Rj* in a key-dependent linear transformation part 341 using the extended key koj. The data Rj* is splitting, 
for instance, to four pieces of 8-bit data in 0 , in 1t in 2 and in 3 in a splitting part 342. The four pieces of data in 0 , in 1p in 2 
and in 3 are nonlinearly transformed to four pieces of data rrtidoo. mid 0 i. mid 0 2 and mid 0 3 in nonlinear transformation 

25 parts 343, 344, 345 and 346, respectively, from which they are input to a key-dependen t linear transformation part 347. 
[0029] The key-dependent linear transformation part 347 is made up of four processing routes 30 0 to 30 3 each of 
which contains at least one exclusive OR circuit as depicted in Fig. 5; these processing routes are logically combined 
by those exclusive OR circuits. Each processing route performs a linear operation (an exclusive-OR operation) of its 
own data with those of the other processing routes to generate uniformed pieces of data in the respective processing 

30 routes; in the example of Fig, 5, they are further linearly processed by extended key k-jj, That is, the pieces of data 
midoo. mid 01 , mid 0 2 and mid 0 3 are fed into the processing routes 30 0 to 30 3 , respectively. In the processing route 30-) 
the pieces of input data mido 0 and mid 0 i are exclusive ORed by an XOR 31 1 , and in the processing route 30 2 the pieces 
of input data mid 02 and mid^ are exclusive ORed by an XOR 31 2 , and the outputs from the XOR 31 n and the XOR 31 2 
are exclusive ORed by an XOR 32 2 . The outputs from the XOR 31 + and the XOR 32 2 are exclusive ORed by an XOR 

35 33-| , then the output from the XOR 33-j and the input data mid 00 are exclusive ORed by an XOR 34 0 , and the output 
from the XOR 32 2 and the input data mid 03 are exclusive ORed by an XOR 34 3 . Furthermore, the outputs from the 
XORs 34 0 , 33 1t 32 2 and 34 3 and extended key k 1i0 , k^, k 1i2 and k 1j3 are exclusive ORed by XORS 35 0 to 363, from 
which mid 10 , mid 11t mid^ and mid 13 are output respectively. That is, the input data mid^, mid 01 , mid^ and mid 03 to 
the processing routes 30 0 to 30 3 are associated with one another and then undergo linear transformations which are 

40 dependent on the key data k 1i0 , k^, k 1i2 and k 1i3 , respectively. In short logical operations given by the following logical 
expressions are performed. 

mid 10 = mid 00 ©mid 02 ©mid 03 ©k 1i0 (11) 
45 mid 11 = mid 02 ©mid 03 ©k 1i1 

mid 12 = mid 00 ©mid 01 ©mid 02 ©mid 03 ©k1 j2 
mid 13 =mid 00 ©mid 01 ©mid 02 ©k li3 

so 

As is evident from these expressions, the output from each processing route of the key-dependent linear transformation 
part 34 contains input data of at least two or more other routes in the form of exclusive ORs in this example, and accord- 
ingly the output data of each route is so uniformed as to contain two or more components of the four pieces of input 
data. 

55 [0030] These pieces of output data mid 10 . mid-n. mid n2 mid 13 are nonlinearly transformed to corresponding 
pieces of data outo, out 1( out 2 and out 3 in nonlinear transformation parts 348, 349, 350 and 351, respectively, and the 
pieces of data are provided as output data from the respective processing routes to a combining part 352, wherein they 
are combined into a single piece of block data Yj*. That is, for example, four pieces of 8-bit data are combined into one 
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piece of 32-bit data. The data Yf is linearly transformed by extended key k 2i to data Yj in a key-dependent linear trans- 
formation part 353; thus; the output data Y ; from the nonlinear function part 304 is generated. The nonlinear transfor- 
mation parts 343 to 346 and 348 to 351 are similar, for instance, to the S-box in the DES. and they are each formed, for 
example, by a ROM whose output data differs with the input data thereto. 
5 [0031] The four nonlinear transformation parts 343 to 346 are arranged in parallel and their transformation proc- 
esses are not associated with one another, and hence they can be executed in parallel; accordingly, an increase in the 
processing time by increasing the number of such nonlinear transformation parts can be deal with by the parallel 
processing thereof. The same is true of the nonlinear transformation parts 348 to 351 . 

[0032] The time necessary for processing in the linear operation part 305 (Fig. 3) and the key<lependent linear 

10 transformation parts 341, 347 and 353 (Fig. 4), which constitute each round processing part 38j, is appreciably shorter 
than the time required to perform processing of the nonlinear transformation parts 343 to 345 and 348 to 351 similar to 
the S-box; therefore, the time necessary for encryption processing is substantially in proportion to the number of S- 
boxes or nonlinear transformation parts used. However, since the key-dependent linear transformation part 347 renders 
plural pieces of input data into uniformed outputs as described previously, it is possible to omit one or more of the non- 

is linear transformation parts 348 to 351 and input the corresponding pieces of data into the combining part 352 when it 
is preknown that the key-dependent linear transformation part 347 performs such a particular linear transformation as 
described above with reference to Fig. 5. This can be done without diminishing the security against the differential and 
linear cryptanalysis, and the workload for encryption can be reduced by the number of nonlinear transformation parts 
thus omitted. For example, when the key-dependent linear transformation part 347 is such as shown in Fig. 5, even if 

20 the nonlinear transformation parts 349 and 350 are omitted and the pieces of data mid 1 , and mid-,2 are fed intact into 
the combining part 352, the security against the differential and linear cryptanalysis remains unchanged but the encryp- 
tion speed increases about 33%. In other words, when the operation of the key-dependent linear transformation part 
347 is predetermined, the presence of one or more of the nonlinear transformation parts 348 to 351 may sometimes 
has nothing to do with the security against the differential and linear cryptanalysis, in which case they can be omitted. 

25 [0033] Incidentally, in Fig. 3 the generation of the extended key {fk, ko 0 , k 10 , k 2 o. koi. k 11 ko( n -i). ki(n--i). k 2(n-i). 

ek} by the extended key generation part 321 can be done in the same manner as in the extended key generating part 
1 6 for the DES in Fig. 1. 

[0034] If the above cryptographic device is designed so that, for example, the nonlinear transformation parts 343 to 
346 and 348 to 351 are each approximated with a probability of p b = 2" 6 by the differential and linear cryptanalysis tech- 

30 niques and that each round processing part 38j performs the nonlinear transformation twice, that is, performs in tandem 
the processing by the transformation parts 343 to 346 and the processing by the transformation parts 348 to 351 , each 
round is approximated with a probability of Pj ^ 2" 12 ; setting the number n of rounds at n = 3m t the round processing of 
the entire cryptographic device is approximated with a probability of P<, 2" 24m . For example, if m = 4 (the number of 
rounds: 12), the probability becomes P < 2" 96 , which satisfies a security condition P < 2 -64 with a smaller number of 

35 rounds than that 1 6 of the DES, providing a cryptographic device with a sufficiently high level of security against the dif- 
ferential and linear cryptanalysis. That is, according to the present invention, the security against cryptanalysis can be 
increased by configuring the round function 12 (Fig. 1) to perform the nonlinear transformation twice in succession. 
[0035] Since the key-dependent initial linear transformation part 302, the key-dependent final linear transformation 
part 308 and the key-dependent linear transformation parts 347 and 353 are linear transformation parts that are 

40 dependent on extended keys, they provide sufficient security against other cryptanalysis as well as the differential and 
linear cryptanalysis, ensuring the implementation of a cryptographic device that attaches prime importance oh security. 
[0036] The present invention is not limited specifically to this embodiment; for example, if it is desirable to speed up 
encryption, it is possible to omit any one or all of these key-dependent initial linear transformation part 302, the key- 
dependent final linear transformation part 308 and the key-dependent linear transformation part 353 as in the embodi- 

45 ment described later on. In this instance, the security against the differential and linear cryptanalysis will not be dimin- 
ished on the one hand, but on the other band the processing speed for encryption can be increased corresponding to 
the number of operations omitted. But there is a fear of providing decreased security against the other cryptanalysis. 
Alternatively, any one or all of the key-dependent initial linear transformation part 302, the key-dependent final transfor- 
mation part 308 and the key-dependent linear transformation parts 347 and 353 may be modified to key-independent 

so linear transformation parts. This will not diminish the security against the other cryptanalysis as well as the differential 
and linear cryptanalysis. and makes it possible to increase the processing speed for encryption by implement optimiza- 
tion. The linear transformation parts each perform a transposition of swapping bit positions of input data in a predeter- 
mined relationship, a rotation of the input data by a predetermined number of bits, and so forth. The key-dependent 
linear transformation parts each perform a rotation by the number of bits corresponding to the extended key, an exclu- 

55 sive OR of the input data and the extended key, and so on. 
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EMBODIMENT 2 

[0037] Fig. 6 illustrates an embodiment which omits middle two of the second four nonlinear transformation parts 
348 to 351 in the nonlinear function part 304 (Fig. 4) of the first embodiment shown in Fig. 3. In this embodiment there 
5 are also omitted the key-dependent initial linear transformation part 302 and the key-dependent final linear transforma- 
tion part 308. 

[0038] The input data P equivalent to a plaintext is input into the cryptographic device via the input part 301 . The 
input data P is split to two pieces of block data Lq and Rq in the initial splitting part 303. The block data Rq is input to the 
nonlinear function part 304 of the 0-th round processing part 38o, together with the extended key ko 0 and k^ stored in 

10 the key storage part 322, wherein it is transformed to data Y 0 through transformation processing. The data Y 0 and the 
data l_o are transformed to data Lo* by an operation in the linear operation part 305. The data Lo* and the data Rq are 
subjected to data-position swapping in the swapping part 306 to provide L 1 = R 0 and R ., = L 0 * . Thereafter, in the i- 

th round processing part 38j (t=1 n-1) the same processing as described above is repeated for the two pieces of 

data Lj and Rj. That is, the data Rj, one of the two pieces of data Lj and Rj, is input into the nonlinear function part 304, 

75 together with the extended key koj and k 2j stored in the key storage part 322, and in the nonlinear function part 304 it is 
transformed to data Yj. The data Yj and the data L s are transformed to data 1^* by an operation in the linear operation 
part 305. The data Lj* and the data Rj are swapped in data position in the swapping part 306 for transformation to 
L M = Rj and R M = Lj*. 

[0039] Letting n represent the repeat count suitable to ensure security of the cryptosystem, two pieces of data 
20 and R n are obtained by such n repeated rounds of processing. These pieces of data Lp and Rn are combined in the final 
combining part 307, and the combined output is provided to the output part 309, from which the output data C is output 
as the ciphertext. 

[0040] To decrypt, the encryption procedure needs only to be reversed, by which the plaintext P can be derived 
from the ciphertext C. 

25 [0041 ] Fig. 7A illustrates the functional configuration of the nonlinear function part 304 of the i-th round processing 
part 38j in the Fig. 6. The data Rj from the preceding round processing part constitutes input data to the nonlinear func- 
tion part 304, together with the extended key k^ and k 2i stored in the key storage part 322. The data Rj is linearly trans- 
formed to data Rj* in the key-dependent linear transformation part 341 using the extended key k^. Then the data Rj* is 
split to four pieces of data in 0 , in 1f in 2 and in 3 in the splitting part 342. The four pieces of data in 0 , in 1p in 2 and in 3 are 

30 nonlinearly transformed to four pieces of data mid 0 o. rnidJn , mid 0 2 and mid 0 3 in the nonlinear transformation parts 343, 
344, 345 and 346, respectively, from which they are input to a linear transformation part 354. In the linear transformation 
part 354 the four pieces of input data are transformed so that they are mutually associated between the four processing 
routes 30 0 to 30 3 as depicted in Fig. 7B. This is the same example as in the case of omitting the logical operation with 
the extended key in Fig. 5 and can be given by the following expressions. 

35 

mid 10 = mid 00 ©mid 02 ©mid 03 (12) 

mid 1 t = mid 02 ©mid 03 

40 mid 12 = mid 00 ©mid 01 ©mid 02 ©mid 03 

mid t 3 =mid QQ^mid 01 ©mid 02 

[0042] By this linear transformation, uniformed data mid 10 , mid-f,, mid 12 and mid 13 are generated, and two pieces 
45 of data mid 10 and mid 13 are nonlinearly transformed to data outo and out 3 in the nonlinear transformation parts 348 and 
351. respectively, after which the four pieces of data outo, rrridn. mid 12 and out 3 are combined into a single piece of 
data Yj* in the combining part 352. Finally, the data Yj* is linearly transformed to the data Yj in the key-dependent linear 
transformation part 353 using the extended key k 2i , by which the output data Yj from the nonlinear function part 304 is 
generated. 

so [0043] The nonlinear transformation parts 343 to 346 are arranged in parallel and their transformation processes 
are not associated with one another, and hence they can be executed in parallel. The same goes for the nonlinear trans- 
formation parts 348 and 351 . In this embodiment, since the number of second nonlinear transformations in each non- 
linear function part 304 is reduced to the outer two (348 and 351) alone, the workload for encryption of decryption can 
be decreased accordingly. 

55 [0044] Incidentally, the extended key kj is data transformed in the extended key generation part 321 from the secret 
key Key input into the cryptographic device via the key input part 320 and stored in the key storage part 322. 
[0045] In the case of the above cryptographic device, for example, if the nonlinear transformation parts 343 to 346, 
348 and 351 are designed to provide an approximate representation with the probability of p b = 2' 6 against the differ- 
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ential and linear cryptanalysis. each round processing part can provide an approximate representation with the same 
probability of Pj <> 2" 12 as in Embodiment 1 ; setting the number n of rounds at n = 3m, the cryptographic device provides 
an approximate representation with the probability of P < 2' 24m as a whole. For example, if m - 4 (the number of rounds: 
12), the probability becomes P ^ 2" 96 . ensuring a sufficiently high level of security against the differential and linear 
cryptanalysis. 

[0046] Moreover, the presence of the key-dependent linear transformation part 353 provides a margin of security 
against other cryptanalysis than the differential and linear cryptanalysis, and the simplified configuration as compared 
with that of Embodiment 1 reduces the workload. That is, the cryptographic device of this embodiment places impor- 
tance on the balance between security and reduced workload. 

EMBODIMENT 3 

[0047] Fig. 8 illustrates an embodiment which omits the key-dependent linear transformation part 353 in the nonlin- 
ear function part 304 of the second embodiment depicted in Fig. 6. The input data P equivalent to a plaintext is input 
into the cryptographic device via the input part 301 . The input data P is split to two pieces of block data Lq and R 0 in the 
initial splitting part 303. The block data R 0 is input to the nonlinear function part 304 of the 0-th round processing part 
38 0 , together with extended key ko stored in the key storage part 322, wherein it is transformed to data Y 0 through trans- 
formation processing. The data Y 0 and the data Lq are transformed to data Lq* by an operation in the linear operation 
part 305. The data Lo* and the data Ft 0 are subjected to data-position swapping in the swapping part 306 for transfor- 
mation to L n = R 0 and R 1 - L 0 * . Thereafter, in the i-th round processing part 38j the same processing as described 
above is repeated for the two pieces of data L s and Rj. That is, the data R t , one of the two pieces of data Lj and R jf is 
input into the nonlinear function part 304, together with extended key kj stored in the key storage part 322, and in the 
nonlinear function part 304 it is transformed to data Yj. The data Yj and the data Lj are transformed to data Lj* by an 
operation in the linear operation part 305. The data Lj* and the data Rj are swapped in data position in the swapping 
part 306 for transformation to L i+1 = R , and R ^ - L ,* ; and two pieces of block data Lj +1 and R i+1 are output. 
[0048] Letting n represent the repeat count suitable to ensure security of the cryptosystem, two pieces of data L„ 
and R n are obtained by such n repeated rounds of processing. These pieces of data arid R n are combined in the final 
combining part 307, and the combined output is provided to the output part 309, from which the output data C is output 
as the ciphertext. 

[0049] The ciphertext C can be deciphered to the plaintext P by following the encryption procedure in reverse. 
[0050] Fig. 9 illustrates the functional configuration of the nonlinear function part 304 in the Fig. 8. The data Rj to 
the nonlinear function part 304 is fed to the key-dependent linear transformation part 341, together with the extended 
key kj stored in the key storage part 322. The data Rj is linearly transformed. to. data Rj* in the key-dependent linear 
transformation part 341 using the extended key kj. Then the data Rj* is split to four pieces of data in 0 , in-,, in 2 and in 3 in 
the splitting part 342. The four pieces of data in 0 . in 1t in 2 and in 3 are nonlinearly transformed to four pieces of data 
midoo. midoi. mid 0 2 and mido3 in the nonlinear transformation parts 343, 344, 345 and 346, respectively, from which 
they are input to the linear transformation part 354. The linear transformation part 354 linearly transforms them to the 
following pieces of data mid 10 , mid-i ^ , mid 12 and mid 13 , for example, in the same manner as described above with ref- 
erence to Fig. 7B in Embodiment 2. 

mid 10 = mid 00 ©mid 02 emid 03 (13) 

mid .j i = mid 02 ©mid 03 

mid 12 = midooSmido^midogemidoa 

mid 13 = mid 00 ©mid 0 ., ©mid 02 

Then the two pieces of data mid n0 and mid 13 are nonlinearly transformed to data outo and out 3 in the nonlinear trans- 
formation parts 348 and 351 , riespectively, after which the four pieces of data outo, mid^ , mid 12 and out 3 are combined 
into a single piece of data in the combining part 352, by which the output data Yj from the nonlinear function pan 304 is 
generated . 

[0051] The nonlinear transformation parts 343 to 346 are arranged in parallel and their transformation processes 
are not associated with one another, and hence they can be executed in parallel. The same goes for the nonlinear trans- 
formation parts 348 and 351 . 

[0052] Incidentally, the extended key K is data transformed in the extended key generation part 321 from the secret 

key Key input into the cryptographic device via the key input part 320 and stored in the key storage part 322. 

[0053] In the case of the above cryptographic device, for example, if the nonlinear transformation parts 343 to 346, 
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348 and 351 are designed to provide an approximate representation with the probability of p b = 2" 6 against the differ 
ential and linear cryptanalysis, each round processing part can provide an approximate representation with the proba - 
bility of pj < 2~ 12 ; setting the number n of rounds at n = 3m, the cryptographic device provides an approximate 
- representation with the probability of P ^ 2" 24m as a whole. For example, if m =4 (the number of rounds: 12), the prob- 
s ability becomes P <, 2* 95 , ensuring a sufficiently high level of security against the differential and linear cryptanalysis. 
[0054] Moreover, since the cryptographic device of this embodiment has a configuration that includes the minimum 
number of parts required to provide a sufficient level of security against the differential and linear cryptanalysis, the 
workload is reduced and the encryption or decryption speed is improved accordingly. 

[0055] In the above, the splitting part 342 in the nonlinear function part 304 needs not always to split the input data 
10 into four but may also split it to an arbitrary number of pieces. In the case splitting the data into four, the number of sec- 
ond nonlinear transformation parts may be reduced to only two as depicted in Figs. 7A and 9. 

[0056] In the following table there are shown, in comparison with the case of the DES of Figs. 1 and 2, the security 
level per round, the number of rounds satisfying the security requirement and the workload (the number of steps) nec- 
essary therefor in the case of using six nonlinear transformation parts (343 to 346, 348, 351) in the nonlinear function 
is part 304 (a round function) depicted in the second and third embodiments descrbed above, in the comparison, the 
embodiments of the present invention used a total of 32 bits for the data to the nonlinear transformation parts 343 to 
346 which correspond to the S-boxes of the DES, and hence the data to each nonlinear transformation part was 8-bit; 
therefore, the size of each S-box was made 8-bit and consequently, the number of S-boxes was four. 



Comparative Table 




No. of S-boxes per round 


Security level per round 


Required No. of rounds 


No. of steps 


DES 


4 


2 -6 


17 


68 


This invention 


6 


2 -12 


9 


54 



[0057] As will be seen from this table, the number of S-boxes (the number of nonlinear transformation parts) per 
30 round in the present invention is larger than in the DES, but the security level per round in the present invention is twice 
that of the DES. On this account, the number of rounds required to meet the security requirement is smaller than in the 
case of DES, and the workload (the number of steps) necessary for providing the security is also smaller. 

EFFECT OF THE INVENTION 

35 

[0058] As described above in detail, according to the present invention, the input data is split to plural pieces of data 
in the nonlinear function part, then these pieces of data are nonlinearly transformed and linearly transformed in asso- 
ciation with each other, and at lease one part of such linearly transformed data is nonlinearly transformed, by which it 
is possible to provide a highly secure cryptographic device for concealing data in data communication or storage. 

40 

Claims 

1. A cryptographic device which encrypts input data by sequentially processing it by a plurality of round processing 
which nonlinearly transforms it using extended key, comprising: 

45 

an initial splitting part which splits the input data to two pieces of block data; 
a key storage part for storing extended key; 

a plurality of cascade-connected round processing parts which are supplied with said two pieces of block data 
and sequentially process them using said extended key; and 
so a final combining part which combines two pieces of block data output from the last round of said plurality of 

cascade-connected round processing parts into a single piece of data and outputs it; 
wherein each of said plurality of round processing part comprises: 

a nonlinear function part which transforms one of two pieces of block data input thereto from the preceding 
stage, depending on extended key stored in said key storage part; 
55 a linear operation part which linearly operates the output data from said nonlinear function part and the other 

of said two pieces of block data; and 

a swapping part which swaps the output data from said linear operation part and the input block data to said 
nonlinear function part and provides the two pieces of swapped data as two pieces of input block data to said 
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round processing part of the next round; and 
wherein said nonlinear function part comprises: 

a key<iependent linear transformation part which linearly transforms input data based on extended key stored 
in said key storage part to thereby generate transformed data; 
5 a splitting part which splits the transformed data from said key-dependent linear transformation part to a plu- 

rality of bit strings; 

a plurality of first nonlinear transformation parts which nonlinearly transform these bit strings, respectively, and 
output transformed data; 

a first linear transformation part which linearly transforms the transformed data from said plurality of first non- 
70 linear transformation parts in association with each other and outputs a plurality of pieces of uniformed data to 
a plurality of routes, respectively; 

a second nonlinear transformation part provided in at least one of said plurality of routes, for nonlinearly trans- 
forming said uniformed data from the corresponding one of said first linear transformation parts, and for out- 
putting the transformed data as data of that route; and 
15 a final combining part which combines data from said plurality of routes into output data of said nonlinear func- 

tion part 

The cryptographic device of claim 1 , wherein said first linear transformation part comprises a key-dependent linear 
operation part which linearly transforms said plurality of pieces of uniformed data based oh extended key stored in 
said key storage part and outputs the plurality of transformed data as data of said plurality of routes. 

The cryptographic device of claim 1 or 2, wherein there is provided a second linear transformation part which line- 
arly transforms the output data from said combining part to provide the output data of said nonlinear function part 

The cryptographic device of claim 3, wherein said second linear transformation part is a linear transformation part 
which performs a linear transformation based on extended key stored in said key storage part. 

The cryptographic device of claim 4, wherein said first linear transformation part comprises at least one exclusive 
OR circuit provided in each of said plurality of routes, for outputting said uniformed data to said each route by an 
exclusive-OR operation of data of said each route and data of other routes. 

The cryptographic device of any one of claims 1 through 5, wherein there is provided an initial linear transformation 
part which linearly transforms said input data and supplies it to said initial splitting part. 

The cryptographic device of claim 6, wherein said initial linear transformation part is a transformation part which 
performs a linear transformation based on extended key stored in said key storage part. 

The cryptographic device of any one of claims 1 through 7, wherein there is provided a final linear transformation 
part which linearly transforms the output data of said final combining part to provide it as the output of said crypto- 
graphic device. 

The cryptographic device of claim 8, wherein said final linear transformation part is a transformation part which per- 
forms a linear transformation based on extended key stored in said key storage part. 

45 1 0. The cryptographic device of any one of claims 1 through 9, wherein said plurality of routes are first; second, third 
and fourth routes arranged in this order. 

1 1 . The cryptographic device of daim 10, wherein said second nonlinear transformation part is provided in each of said 
four routes. 

so 

1 2. The cryptographic device of claim 10, wherein said second nonlinear transformation part is provided in each of said 
first and fourth routes. 

1 3. The cryptographic device of claim 12, wherein said first linear transformation part comprises: 

55 

a first exclusive OR circuit provided in said second route, for carrying out the exclusive-OR between data of 
said first route and data of said second route; 

a second exclusive-OR circuit provided in said third route, for carrying out the exclusive OR between data of 
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said fourth route and data of said third route; 

a third exclusive-OR circuit provided in said third route, for carrying out the exclusive OR between the output 
of said second exclusive-OR circuit and the output of said first exclusive-OR circuit; 

a fourth exclusive-OR circuit provided in said second route, for carrying out the exclusive OR between the out- 
put of said first exclusive-OR circuit and the output of said third exclusive-OR circuit 

a fifth exclusive-OR circuit provided in said first route, for carrying out the exclusive OR between the data of 
said first route and the output of said fourth exclusive-OR circuit; and 

a sixth exclusive-OR circuit provided in said fourth route, for carrying out the exclusive OR between the data of 
said fourth route and the output of said third exclusive-OR circuit. 
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